<template>
    <div>
        
        <div id="slider" class="mui-slider">
            <div id="sliderSegmentedControl" class="mui-scroll-wrapper mui-slider-indicator mui-segmented-control mui-segmented-control-inverted">
                <div class="mui-scroll">
                    <a :class="['mui-control-item', item.id==0?'mui-active':'']" v-for="item in cates" :key="item.id" @click="getPhotoListByCateId(item.id)">
                        {{item.title}}
                    </a>
                </div>
            </div>
        </div>
        <!-- 图片列表区域 -->
        <ul class="photo-list">
            <router-link v-for="item in list"  :key="item.id" :to="'/home/photoInfo/' + item.id" tag="li">
                <img v-lazy="item.img_url">
                <div class="info">
                    <h1 class="info-title">{{item.title}}</h1>
                    <div class="info-body">{{item.zhaiyao}}</div>
                </div>
            </router-link>
        </ul>
    </div>
</template>
<script>
import mui from '../../../lib/MUI/js/mui.min.js'

export default {
    data() {
        return {
            cates: [],   // 所有分类
            list: [],   //图片列表的数据
        }
    },
    created() {
        this.getAllCategory();
        this.getPhotoListByCateId(0)
    },
    mounted() {   
        //当组件中的dom结构被渲染好并放到页面中后，会执行这个钩子函数
        // 如果要操作元素，最好在mounted里面，因为这里的dom结构是最新的
        //初始化滑动控件
        mui('.mui-scroll-wrapper').scroll({
            deceleration: 0.0005 //flick 减速系数，系数越大，滚动速度越慢，滚动距离越小，默认值0.0006
        });
    },
    methods: {
        getAllCategory() {  //获取所有的分类
            this.$http.get('http://www.liulongbin.top:3005/api/getimgcategory').then( result => {
                if( result.body.status === 0){
                    result.body.message.unshift( {title:'全部', id: 0} )
                    this.cates = result.body.message
                }
            })
        },
        getPhotoListByCateId(cateId){  //根据分类id,获取图片列表
            this.$http.get('http://www.liulongbin.top:3005/api/getimages/' + cateId ).then( result => {
                if( result.body.status === 0){
                    // console.log(result.body)
                    this.list = result.body.message
                }
            })   
        }
    }

}
</script>

<style lang="scss" scoped>
    *{
        touch-action: pan-y; 
    }
    //加这个*样式，是谷歌里面有一个警告，加上这个样式 可以去掉警告
    //touch-action css属性  用于指定某个给定的区域是否允许用户操作，以及如何响应用户操作（比如浏览器自带的滑动，缩放等）
    .photo-list{
        list-style: none;
        margin: 0;
        padding:10px;
        padding-bottom:0;
        li{
            background-color: #ccc;
            text-align:center;
            margin-bottom:10px;
            box-shadow: 0 0 9px #999;
            position: relative;
            img{
                width:100%;
                vertical-align: middle;
            }
            img[lazy=loading] {
                width: 40px;
                height: 300px;
                margin: auto;
            }
            
            .info{
                color:#fff;
                text-align:left;
                position: absolute;
                bottom:0;
                background-color: rgba(0,0,0,.4);
                max-height:84px;
                .info-title{
                    font-size:14px;
                }
                .info-body{
                    font-size:13px;
                }
            }
        }
    }
    
</style>

